package com.chenl.provider.DEMOS.日志相关.全链路日志以及Spring线程池装饰器的使用;

import org.slf4j.MDC;
import org.springframework.core.task.TaskDecorator;

import java.util.Map;

/**
 * 任务适配器MdcTaskDecorator
 */
public class MdcTaskDecorator  implements TaskDecorator {
    @Override
    public Runnable decorate(Runnable runnable) {
        Map<String, String> map = MDC.getCopyOfContextMap();//1.获取MDC中的内容
        String user = UserThreadLocal.getUser();//2.还可以获取原来线程中的内容，设置到异步线程中
//        System.out.println("这次的user为："+user);
        return ()->{
            try {
                MDC.setContextMap(map);//1.1在任务执行前,先获取主线程中的MDC中的Map,传递到线程池的子线程中
                UserThreadLocal.setUser(user);//2.2
                runnable.run();
            } finally {
                MDC.clear();
            }
        };
    }
}
